<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "../common/link.ftl"/>
</head>
<script>
    $(function () {
        $('#editForm').bootstrapValidator({
            message: '未知错误',
            feedbackIcons: {
                valid: 'glyphicon glyphicon-ok',
                invalid: 'glyphicon glyphicon-remove',
                validating: 'glyphicon glyphicon-refresh'
            },
            fields: {
                name: {
                    validators: {
                        notEmpty: {
                            message: '用户名不能为空'
                        },
                        stringLength: {
                            min: 2,
                            max: 5,
                            message: '用户名长度需要在2 到 5 之间'
                        }
                    }
                },
                email: {
                    validators: {
                        notEmpty: {
                            message: '邮箱不能为空'
                        },
                        emailAddress: {
                            message: '这不是邮箱!'
                        }
                    }
                },
                password: {
                    validators: {
                        notEmpty: {
                            message: '密码不能为空'
                        }
                    }
                },
                repassword: {
                    validators: {
                        notEmpty: {
                            message: '确认密码不能为空！'
                        },
                        identical: { // 比较是否相同，否的话校验不通过
                            field: 'password', // 和 password 字段比较
                            message: '两次输入密码不一致！'
                        }
                    }
                },
                age: {
                    validators: {
                        notEmpty: {
                            message: '年龄不能为空！'
                        },
                        between: { // 数值范围校验
                            min: 18,
                            max: 60,
                            message: '请输入正常的年龄，范围为 %s 到 %s！'
                        }
                    }
                },
            }
        })
        .on('success.form.bv', function(e) {
            //拦截默认的submit提交请求
            e.preventDefault();
            var $form = $(e.target);
            var bv = $form.data('bootstrapValidator');
            $(".selfRoles>option").prop("selected", true);
            $.post($form.attr('action'), $form.serialize(), function(data) {
                $.messager.confirm("温馨提示",data.msg,function () {
                   if(data.success){
                       location.href="/employee/list.do";
                   }
                });
         }, 'json');
        });
    });

</script>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl"/>
    <!--菜单回显-->
    <#assign currentMenu="employee">
    <#include "../common/menu.ftl"/>
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id" >
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name" name="name" value="${(employee.name)!}" placeholder="请输入用户名">
                        </div>
                    </div>

                    <#if !(employee)??>
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>

                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                               <#list depts as dept>
                                    <option value="${dept.id}">${dept.name}</option>
                               </#list>
                            </select>
                            <script>
                                $("#dept option[value='${(employee.dept.id)!}']").prop("selected", true);
                            </script>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                            <script>
                                var $roleDiv;
                                $('#admin').click(function () {
                                   // 获取选中状态
                                   var checked = $(this).prop('checked');
                                   if(checked){ // 删除角色分配的页面元素
                                       $roleDiv = $('#role').detach();
                                   }else{ // 还原
                                       $('#adminDiv').after($roleDiv)
                                   }
                                });

                            </script>
                            <#if (employee.admin)!false>
                                <script>
                                    $("#admin").prop("checked", true);
                                </script>
                            </#if>
                        </div>
                    </div>
                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                     <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                     </#list>
                                </select>
                            </div>


                            <script>
                                function moveSelected(srcClass, targetClass) {
                                    $('.' + targetClass).append($('.' + srcClass + ' > option:selected'));
                                }

                                function moveAll(srcClass, targetClass) {
                                    $('.' + targetClass).append($('.' + srcClass + ' > option'));
                                }
                            </script>
                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>
                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="roleIds">
                                    <#list (employee.roles)! as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <script>
                                // 页面角色去重
                                var roleIds = [];
                                $('.selfRoles > option').each(function (i, domEle) {
                                    roleIds.push($(domEle).val())
                                });

                                $('.allRoles > option').each(function (i, domEle) {
                                    var value = $(domEle).val();
                                    if($.inArray(value, roleIds) >= 0){
                                        $(domEle).remove();
                                    }
                                });
                            </script>

                            <script>
                                // 页面加载完, 根据用户是不是超管,删除页面role分配的页面元素
                                $(function () {
                                   var checked = $('#admin').prop('checked');
                                   if(checked){
                                       $roleDiv = $('#role').detach();
                                   }
                                });
                            </script>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6" style="text-align: center">
                            <button id="submitBtn" type="submit" class="btn btn-primary">保存</button>
                            <script>
                               /* $('#submitBtn').click(function () {
                                    $('.selfRoles > option').prop('selected', true);
                                    $("#editForm").ajaxSubmit(function (data) {
                                        $.messager.confirm("温馨提示",data.msg,function () {
                                            location.href="/employee/list.do";
                                        })
                                    });
                                });*/
                            </script>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>
                </form>
            </div>
        </section>
    </div>
    <#include "../common/footer.ftl"/>
</div>
</body>
</html>
